<template>
  <el-form :model="user" :rules="rules2" ref="user" label-position="left" label-width="0px" class="demo-ruleForm login-container">
    <h3 class="title">系统登录</h3>
    <el-form-item prop="username">
      <el-input type="text" v-model="user.username" auto-complete="off" placeholder="账号"></el-input>
    </el-form-item>
    <el-form-item prop="password">
      <el-input type="password" v-model="user.password" auto-complete="off" placeholder="密码"></el-input>
    </el-form-item>
    <el-checkbox v-model="checked" checked class="remember">记住密码</el-checkbox>
    <el-form-item style="width:100%;">
      <el-button type="primary" style="width:100%;" @click.native.prevent="accountLogin" :loading="logining">登录</el-button>
      <!--<el-button @click.native.prevent="handleReset2">重置</el-button>-->
    </el-form-item>

    <el-form-item style="width:100%;">
      <el-button type="success" style="width:100%;" @click.native.prevent="goRegister" :loading="logining">商店入住</el-button>
      <!--<el-button @click.native.prevent="handleReset2">重置</el-button>-->
    </el-form-item>
  </el-form>
</template>

<script>
  import { requestLogin } from '../api/api';
  //import NProgress from 'nprogress'
  export default {
    data() {
      return {
        logining: false,
        user: {
          username: '东邪',
          password: '1',
          type:"0"
        },
        rules2: {
          username: [
            { required: true, message: '请输入账号', trigger: 'blur' },
            //{ validator: validaePass }
          ],
          password: [
            { required: true, message: '请输入密码', trigger: 'blur' },
            //{ validator: validaePass2 }
          ]
        },
        checked: true
      };
    },
    methods: {

      // 动态添加路由函数
      initIndexRouters() {
        debugger;
        if (!localStorage.menus) {
          return;
        }
        //防止重复配置路由：5就是main.js中路由的个数 - 如果你的静态路由是6个这里要写成6
        if (this.$router.options.routes.length > 6) {
          return;
        }
        let menus = localStorage.getItem('menus');
        menus = JSON.parse(menus);
        let tempRouters = [];
        menus.forEach(menu => {
          let indexRouter = {
            path: '/',
            iconCls: menu.icon,
            name: menu.name,
            component: resolve => require(['@/views/Home'], resolve),
            children: []
          }
          menu.children.forEach(cMenu => {
            let cr = {
              path: cMenu.url,
              name: cMenu.name,
              component: resolve => require(['@/views/' + cMenu.component], resolve)
            }
            indexRouter.children.push(cr)
          })
          tempRouters.push(indexRouter)
          this.$router.options.routes.push(indexRouter)
        })
        //动态路由配置
        this.$router.addRoutes(tempRouters);
      },







      // 商家入住函数
      goRegister(){

        // 跳路由到登录界面
        this.$router.push({ path: '/shopRegister' });

      },
      handleReset2() {
        this.$refs.user.resetFields();
      },
      accountLogin(ev) {
        this.$refs.user.validate((valid) => {
          if (valid) {
            //_this.$router.replace('/table');
            this.logining = true;

            //NProgress.start();
            this.$http.post("/login/account",this.user)
            .then(result=>{
              this.logining = false;
              result = result.data;
              if (result.success){// 登录成功
                let{token,logininfo,permissions,menus} = result.resultObj;
                // 1.保存token和logininfo
                localStorage.setItem("token",token)

                // 将对象转换为json格式JSON.stringify(logininfo)
                localStorage.setItem("logininfo", JSON.stringify(logininfo))

                // 保存菜单信息
                localStorage.setItem("permissions",JSON.stringify(permissions))

                // 保存权限信息
                localStorage.setItem("menus", JSON.stringify(menus))

                // 根据用户菜单权限，动态展示菜单，用户登录成功后，调用动态追加路由函数
                this.initIndexRouters();


                // 2.跳转页面
                this.$router.push({ path: '/echarts' });
              }else {// 登录失败
                this.$message({
                  message:result.message,
                  type: 'error'
                });
              }

            })
            .catch(result=>{
              this.$message({
                message: "系统繁忙，请稍后再试",
                type: 'error'
              });

            })
          /*  var loginParams = { username: this.user.account, password: this.user.checkPass };
            requestLogin(loginParams).then(data => {
              this.logining = false;
              //NProgress.done();
              let { msg, code, user } = data;
              if (code !== 200) {
                this.$message({
                  message: msg,
                  type: 'error'
                });
              } else {
                sessionStorage.setItem('user', JSON.stringify(user));
                this.$router.push({ path: '/echarts' });
              }
            });*/
          } else {
            console.log('error submit!!');
            return false;
          }
        });
      }
    }


  }

</script>

<style lang="scss" scoped>
  .login-container {
    /*box-shadow: 0 0px 8px 0 rgba(0, 0, 0, 0.06), 0 1px 0px 0 rgba(0, 0, 0, 0.02);*/
    -webkit-border-radius: 5px;
    border-radius: 5px;
    -moz-border-radius: 5px;
    background-clip: padding-box;
    margin: 180px auto;
    width: 350px;
    padding: 35px 35px 15px 35px;
    background: #fff;
    border: 1px solid #eaeaea;
    box-shadow: 0 0 25px #cac6c6;
    .title {
      margin: 0px auto 40px auto;
      text-align: center;
      color: #505458;
    }
    .remember {
      margin: 0px 0px 35px 0px;
    }
  }
</style>